Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Gradual typing #1217

Open
wants to merge 11 commits into
base: main
Choose a base branch
from
Open

Gradual typing #1217

wants to merge 11 commits into from

Conversation

akaihola
Copy link
Contributor

@akaihola akaihola commented Aug 29, 2024

Here's another stab at adding typing since #639 was closed.

I acknowledge that Paul has expressed that he isn't currently planning to add type hints, and that reviewing type hints would be a burden.

However, I believe this extremely minimal Mypy configuration and a minimal set of changes not only make Mypy pass, but also enable to use it to check some types, and allow development to continue without requiring full type hints everywhere.

Mypy takes over the burden of reviewing type annotations from humans.

Most notably, functions with no type hints are not checked by Mypy at all with this configuration. This allows adding type hints just only to select sections of the code base. It is still of course possible to gradually add typing overall and increase Mypy's strictness if desired.

See Using mypy with an existing codebase for more information.

@@ -35,7 +38,7 @@ class CoderPrompts:
" stop and wait for your approval."
)

repo_content_prefix = """Here are summaries of some files present in my git repository.
repo_content_prefix: str | None = """Here are summaries of some files present in my git repository.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The type union syntax X | Y is only available in Python 3.10, but Aider still supports Python 3.9.
Instead, this should be

Suggested change
repo_content_prefix: str | None = """Here are summaries of some files present in my git repository.
repo_content_prefix: typing.Optional[str] = """Here are summaries of some files present in my git repository.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

On line 1 of this file, I've added

from __future__ import annotations

which makes sure X | Y is supported on Python 3.9.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Need to put that in the tests too it looks like:

TypeError: unsupported operand type(s) for |: 'type' and 'NoneType'

@nedtwigg
Copy link

I would think that typing an untyped python codebase is exactly the kind of thing that Aider itself would be great at. Typing the edges is trivial, that leads to type errors, fix those, that leads to new type errors, fix those, etc.

I also think if it's worth adding type annotations at all, then it's worth bumping to a Python version that supports the latest / greatest versions of them. Aider seems like more of an end-user thing than infrastructure library, seems okay for it to be more aggressive in bumping requirements than a typical library.

@Faolain
Copy link

Faolain commented Sep 22, 2024

Amazing work as this will make aider improving itself even better (from experience llms do quite well with typed code)

@akaihola akaihola force-pushed the gradual-typing branch 4 times, most recently from 0f49a3d to 6416497 Compare October 5, 2024 19:15
@CLAassistant
Copy link

CLAassistant commented Oct 16, 2024

CLA assistant check
All committers have signed the CLA.

@akaihola akaihola force-pushed the gradual-typing branch 2 times, most recently from 1a50afe to 77438bb Compare December 29, 2024 20:54
@akaihola
Copy link
Contributor Author

I rebased on main and fixed all typing errors which had appeared meanwhile. Also added a requirements file for running Mypy. It includes Mypy itself and some type stub packages. The workflow now uses this requirements file as well as other requirements files needed for type checking.

@ryanpeach
Copy link

ryanpeach commented Jan 22, 2025

Have you considered pyright instead? Pyright is fast enough to work in your vscode and neovim live, and can go in your pre-commit.

Also we should put typing into the github actions.

Personally I think typing will make aider better both in scripting mode (making it more understandable to devs, less likely for bugs) and for self-modification via aider (it will improve the linting loop, and will give more informative repo maps).

I'd definitely love to see a blog post about the accuracy of aider edits under properly typed vs untyped code generation.

Copy link

@ryanpeach ryanpeach left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Very minimal IMO. I like it (though I have no authority)

run: |
python -m pip install --upgrade pip
pip install '.[browser,dev,playwright,mypy]'

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

add flake8 and black checks as they are in the pre-commit

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@ryanpeach ryanpeach mentioned this pull request Jan 22, 2025
Copy link

@ryanpeach ryanpeach left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A few more lint comments

name: Linting

on:
push:
Copy link

@ryanpeach ryanpeach Jan 22, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure why we need this on push, just PR right?

- name: Set up Python 3.12
uses: actions/setup-python@v5
with:
python-version: "3.12"

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Use a matrix like in the other workflows

@ryanpeach
Copy link

ERROR: Cannot install None, aider-chat and aider-chat[browser,dev,mypy,playwright]==0.1.dev1+g1aa8de2 because these package versions have conflicting dependencies.

The conflict is caused by:
    aider-chat 0.1.dev1+g1aa8de2 depends on attrs==24.3.0
    aiohttp 3.11.11 depends on attrs>=17.3.0
    jsonschema 4.23.0 depends on attrs>=22.2.0
    referencing 0.36.0 depends on attrs>=22.2.0
    aider-chat[browser,dev,mypy,playwright] 0.1.dev1+g1aa8de2 depends on attrs==24.3.0
    aider-chat[browser,dev,mypy,playwright] 0.1.dev1+g1aa8de2 depends on attrs==24.3.0; extra == "browser"
    aider-chat[browser,dev,mypy,playwright] 0.1.dev1+g1aa8de2 depends on attrs==24.2.0; extra == "mypy"

To fix this you could try to:
1. loosen the range of package versions you've specified
2. remove package versions to allow pip to attempt to solve the dependency conflict

https://github.com/OnScale/aider-stateless/actions/runs/12914071198/job/36012781606?pr=7

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants